草庐IT

sql - Go SQL查询不一致

全部标签

go - 使用 golang channel 的结果不一致

我用Go编写了一个任务,用于从一堆文本文件中获取唯一列表。我使用channel进行了一些并行化,现在结果不一致-每次使用相同的输入文件输出/不输出5条记录的差异。我正在用gorunprocess.go|测试它wc-l在Fedorax86_64、go1.1.2、8核amd上。代码是:packagemainimport("fmt""os""io""encoding/csv""regexp""log")var(cleanRe*regexp.Regexp=regexp.MustCompile("[^0-9]+")commarune='\t'fieldsPerRecord=-1)funcclea

sql - 使用数据库/sql 包创建通用代码?

我最近实现了apackage使用database/sql包。通过将SQL限制为非常简单的选择/更新/插入语句,我假设该包可以与database/sql支持的所有DBMS一起工作。然而,事实证明有些数据库使用?作为占位符值,而其他数据库使用$1、$2等,这意味着准备好的语句适用于某些DBMS,但不适用于其他DBMS。所以我想知道是否有任何技术可以使所有受支持的驱动程序以通用方式工作?或者是否有必要在所有地方都使用特定于DBMS的代码?(我认为这会使database/sql提供的抽象有点毫无意义)。我想使用非准备语句也不是一个选项,因为不同的DBMS有不同的方法来转义参数。有什么建议吗?

mysql - Google 是否不鼓励使用第 3 方 Go 驱动程序来使用云 sql?

根据thisCloudSQL有一个Go库。GoogleCloudSQLonAppEngine:user@cloudsql(project-id:instance-name)/dbname但是根据GAE站点,您可以(也许应该?)仅使用java或python连接到CloudSQL:https://developers.google.com/cloud-sql/faq#languagesCanIuselanguagesotherthanJavaorPython?OnlyJavaandPythonaresupportedforGoogleCloudSQL.我正在确定GAE是否适合我的Go应用程

go - 使用 SQL 驱动程序交叉编译 Go 程序

我有一个非常简单的Go测试程序,它使用OracleSQL驱动程序(“github.com/mattn/go-oci8”)。我在OSX上构建并测试它并且它可以工作。现在想在linux上交叉编译运行。我是这样编译的:CGO_ENABLED=0GOOS=linuxGOARCH=amd64goinstallgithub.com/mattn/go-oci8CGO_ENABLED=0GOOS=linuxGOARCH=amd64gobuildmyoracle.go但是当我尝试运行它时,我得到了$./myoraclesql:unknowndriver"oci8"(forgottenimport?)代码

mysql - 如何使用 github.com/go-sql-driver/mysql 指定服务器的端口号?

我正在为MySQL使用以下包http://godoc.org/github.com/go-sql-driver/mysql#MySQLDriver.Open我的代码是:import("bufio""database/sql"_"github.com/go-sql-driver/mysql")db,err:=sql.Open("mysql","me_id:username@tcp(db1.abc.com)/dataname?timeout=2s")但我收到错误消息error:dialtcp:missingportinaddressdb1.abc.com无论如何我可以指定没有任何端口号的服

sql - 在 Go 中为 PGSQL 函数提供参数

我正在尝试使用db.QueryRow()将参数传递给Golang中的以下函数,但它似乎不接受通常的?。DROPFUNCTIONIFEXISTSupsertplatform(pTokenvarchar);CREATEFUNCTIONupsertplatform(pTokenvarchar)RETURNSintas$$DECLARE_idint=NULL;BEGINLOOPUPDATEpublic.platformSETplatformToken=pTokenWHEREuserID=3ANDplatformID=2RETURNINGidinto_id;IFNOTFOUNDTHENBEGIN

database - 无法获取更新查询的数据库响应以在 go 中进一步执行

我想更新远程数据库表中的数据并执行进一步的任务但无法执行。在插入查询中使用相同的代码,我能够在同一个表中插入值,我很快就会得到响应并继续执行进一步的任务。但在更新查询中,它确实更新了表中的值,但无法继续。这是我尝试过的示例代码:packagesrcimport("github.com/go-sql-driver/mysql""database/sql""fmt""log""net")const(DB_NAME="test_db"DB_HOST="remotedbipaddress:port"DB_USER="username"DB_PASS="password")const(buffe

sql - 如何映射m :n relation to slice field?

我有一个结构Person:typePersonstruct{Idint64NamestringColors[]string}它应该从person表中获取数据:id|name---------1|Joe2|Moe和一个person_color表:person_id|color-----------------1|black1|blue2|green通过SELECTp.id,p.name,pc.colorFROMpersonASpINNERJOINperson_colorASpcONpc.person_id=p.id我将两个表合并到:id|name|color---------------

go func(*DB) 不存在该行时查询返回

签名是func(db*DB)Query(querystring,args...interface{})(*Rows,error)。如果查询和调用是:Gofunc(*DB)Query返回什么:rows,err:=db.Query("SELECTusernameFROMuserstableWHEREusername=$1",registerInstance.Username)当userstable表中没有这样的行时。它是返回一个非零的error还是返回空字符串值作为Result并且非nil的error只有在错误时才返回发生了吗? 最佳答案

mongodb - 使用 Go 在 MongoDB 中指定查询

对于如何将JavascriptJSON命令转换回go会理解的东西感到困惑。好的,这是mongoshell中的查询:db.customers.find({acct_balance:{$gt:100000}},{firstName:1,surname:1,acct_balance:1,_id:0})结果::{“firstName”:“Susann”,“surname”:“Ulisch”,“acct_balance”:238897.45}{“firstName”:“Parker”,“surname”:“Peet”,“acct_balance”:443314.13}现在我想在Go中复制该查询。